<article id="wikiArticle">
<div></div>
<h2 id="错误提示">错误提示</h2>
<pre><code class="language-javascript">TypeError: invalid 'in' operand "x" (Firefox)
TypeError: Cannot use 'in' operator to search for 'x' in y (Chrome)
</code></pre>
<h2 id="错误类型">错误类型</h2>
<p><a href="Reference/Global_Objects/TypeError" title="TypeError（类型错误） 对象用来表示值的类型非预期类型时发生的错误。"><code>TypeError</code></a></p>
<h2 id="哪里出错了？">哪里出错了？</h2>
<p><a href="/en-US/docs/Web/JavaScript/Reference/Operators/in"><code>in</code> 操作符</a>只可以用来检测对象中是否存在某个属性，而不能用来在字符串、数字或者其他基本类型的数据中进行检索。</p>
<h2 id="示例">示例</h2>
<h3 id="在字符串中进行检索">在字符串中进行检索</h3>
<p>与其他语言不同（如 Python），不能使用 <a href="/en-US/docs/Web/JavaScript/Reference/Operators/in"><code>in</code> 操作符</a>在字符串中进行检索。</p>
<pre><code class="language-js example-bad">"Hello" in "Hello World"; 
// TypeError: invalid 'in' operand "Hello World"
</code></pre>
<p>可以使用 <a href="Reference/Global_Objects/String/indexOf" title="indexOf() 方法返回调用  String 对象中第一次出现的指定值的索引，开始在 fromIndex进行搜索。"><code>String.prototype.indexOf()</code></a> 来代替：</p>
<pre><code class="language-js example-good">"Hello World".indexOf("Hello") !== -1; 
// true</code></pre>
<h3 id="操作数不能为_null_或者_undefined">操作数不能为 null 或者 undefined</h3>
<p>确保你将要进行探测的对象不为 <a href="Reference/Global_Objects/null" title="值 null 特指对象的值未设置。它是 JavaScript 基本类型 之一。"><code>null</code></a> 或者  <a href="Reference/Global_Objects/undefined" title="undefined是全局对象的一个属性。也就是说，它是全局作用域的一个变量。undefined的最初值就是原始数据类型undefined。"><code>undefined</code></a>.</p>
<pre><code class="language-js example-bad">var foo = null;
"bar" in foo;
// TypeError: invalid 'in' operand "foo"
</code></pre>
<p>in 操作符的预期操作数只有对象类型。</p>
<pre><code class="language-js example-good">var foo = { baz: "bar" };
"bar" in foo; // false

"PI" in Math; // true
"pi" in Math; // false
</code></pre>
<h3 id="在数组中进行检索">在数组中进行检索</h3>
<p>当使用 in 操作符来对 <a href="Reference/Array" title="REDIRECT Array"><code>Array</code></a> 对象进行检索的时候一定要特别小心，因为它检测的是索引值而不是位于索引位置的值。</p>
<pre><code  class="language-javascript">var trees = ['redwood', 'bay', 'cedar', 'oak', 'maple'];
3 in trees; // true
"oak" in trees; // false</code></pre>
<h2 id="相关内容">相关内容</h2>
<ul>
<li><a href="/en-US/docs/Web/JavaScript/Reference/Operators/in"><code>in</code> operator</a></li>
</ul>
</article>